草庐IT

CountDownLatch和ExecutorService 线程池cachedThreadPool.submit

全部标签

java - 多线程不比单线程快(简单循环测试)

我正在试验一些多线程结构,但不知何故,多线程似乎并不比单线程快。我将其缩小为一个非常简单的测试,其中包含一个嵌套循环(1000x1000),系统只在其中计算。下面我贴出了单线程和多线程的代码以及它们是如何执行的。结果是单线程完成循环大约需要110ms,而两个线程也需要大约112ms。我不认为问题是多线程的开销。如果我只将两个Runnable中的一个提交给ThreadPoolExecutor,它的执行时间是单线程的一半,这是有道理的。但是添加第二个Runnable会使它慢10倍。两个3.00Ghz内核都在100%运行。我认为这可能是特定于pc的,因为其他人的pc在多线程上显示了双倍速度的

java - 这个线程安全的字节序列生成器有什么问题?

我需要一个字节生成器来生成从Byte.MIN_VALUE到Byte.MAX_VALUE的值。当它达到MAX_VALUE时,应该从MIN_VALUE重新开始。我已经使用AtomicInteger编写了代码(见下文);但是,如果并发访问并且使用Thread.sleep()人为地减慢代码(如果没有hibernate,它运行良好;但是,我怀疑它对于并发问题的出现来说太快了),代码似乎不会正常运行。代码(添加了一些调试代码):publicclassByteGenerator{privatestaticfinalintINITIAL_VALUE=Byte.MIN_VALUE-1;privateAt

java - 为什么 Servlet 中的实例变量不是线程安全的

这个问题在这里已经有了答案:Howdoservletswork?Instantiation,sessions,sharedvariablesandmultithreading(8个答案)关闭6年前。当我阅读HeadFirstServletandJSP时,他们说实例变量是非线程安全的。我不是很理解这个说法。例如:我有一个名为ActionServlet.java的servlet。每次,每个用户的请求被发送到服务器,容器将创建一个新线程并创建新的ActionServlet实例。ActionServlet可能有一个结构:publicclassActionServletextendsHttpSe

java - 用于查看 Java 进程中的线程的实用程序

我在Windows机器上有一个Java应用程序,它时不时地固定CPU。想运行一个实用程序来了解该应用程序正在创建多少线程等。有这样的工具吗? 最佳答案 jconsole包含在jdk中,包含线程/内存/cpu监控 关于java-用于查看Java进程中的线程的实用程序,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1110664/

java - 在多线程环境下使用 HashMap

我正在做一个面试题onJavaRevisited我很难理解这个问题:What’swrongwithusingaHashMapinamultithreadedenvironment?Whenget()methodgointoaninfiniteloop?在我看来,使用HashMap不是问题在多线程环境中,只要我们的应用程序没有访问/读取正在修改创建的HashMap的线程,而不是简单地访问HashMap。因此,在我看来,只要在应用程序中我们只是访问HashMap就没有问题。在多线程环境中。请让我知道我的理解是否正确。 最佳答案 What

java - 非托管线程 Spring Quartz Websphere Hibernate

看来我们使用Quartz-JDBCJobStore以及Spring、Hibernate和Websphere的实现正在抛出非托管线程。我读了一些书,发现了一篇来自IBM的技术文章,指出将Quartz与Spring一起使用会导致这种情况。他们建议使用CommnonJ来解决这个问题。我做了一些进一步的研究,到目前为止我看到的唯一例子都是处理不在数据库中的计划旧JobStore。所以,我想知道是否有人有解决此问题的示例。谢谢 最佳答案 我们有一个可行的解决方案(实际上有两个)。1)更改quartz源代码以将WorkManager守护线程用作

java - 在多线程(Java 或 .Net)程序中,我可以假设复制变量是原子的吗?

当我想知道这个问题时,我正在担心我正在设计的应用程序中的竞争条件。假设我有一个大型数组或某种集合,由我的程序的一个组件管理,我们称该组件为Monitor。它的工作是定期检查集合是否“脏”,即。e.最近发生了变化,如果是这样,将快照写入磁盘(这是为了在发生崩溃时检查应用程序)并再次将其标记为干净。同一程序的其他组件,运行在不同的线程中,调用监视器的方法向数组/集合中添加数据或修改数据。这些方法将集合标记为脏。现在,更改方法在其他组件的线程中运行,对吧?如果我不那么幸运,它们可能会在快照写入磁盘时被调用,更改已经写入的数据,设置脏标志,然后监视器的线程将其取消设置,而不会保存更改(它改变时

Java:线程技术和概念

在使用线程时,我有时会将它们想象成将空间上下文中的对象之间的3维或更多维互连编织在一起。这不是一般用例场景,但对于我所做的事情来说,这是一种有用的思考方式。您是否使用了任何有助于线程化的API?您是否以不将线程概念化为进程的方式使用线程? 最佳答案 您是否使用任何有助于线程化的API?你是说java.util.concurrent的应用程序?FunctionalJava获得了一些有助于并发编程的构造,如开始here的多部分教程中所述.您是否以未将线程概念化为进程的方式使用线程?是的,线程根本没有概念化。以异步任务运行器为例。它在幕后

java - 我的类(class)线程安全吗?如果不是为什么?

我的类是线程安全的吗?如果不是,为什么?classFoo{booleanb=false;voiddoSomething()throwsException{while(b)Thread.sleep();}voidsetB(booleanb){this.b=b;}} 最佳答案 代码不是线程安全的,因为正在运行的线程可能会看到更改,直到代码被编译(可能在稍后的随机点)并且您不再看到更改。顺便说一句:这使得测试变得非常困难。例如如果您睡1秒钟,您可能会在将近三个小时内看不到这种行为。即它可能有效,也可能无效,你不能仅仅因为它有效就说它会继续

java - 如何顺序执行ExecutorService中的任务?

我有三个连接的线程,即第二个线程在第一个死后执行。这是我的代码:publicclassMain{publicstaticvoidmain(Stringargs[])throwsException{finalThreadthrdA=newThread(()->System.out.println("Message1"));finalThreadthrdB=newThread(()->System.out.println("Message2"));finalThreadthrdC=newThread(()->System.out.println("Message3"));thrdA.sta